package com.sky.mapper;

import com.sky.entity.User;
import org.apache.ibatis.annotations.Insert;
import org.apache.ibatis.annotations.Mapper;
import org.apache.ibatis.annotations.Options;
import org.apache.ibatis.annotations.Select;

import java.time.LocalDateTime;
import java.util.Map;

/**
 * 目标：
 *
 * @author Ashely
 * @date 2024/6/14 20:34
 */
@Mapper
public interface UserMapper {
    @Select("select * from user where openid = #{openId}")
    User getByOpenId(String openId);
@Insert("insert into user (openid, name, phone, sex, id_number, avatar, create_time) values (#{openid}, #{name}, #{phone}, #{sex}, #{idNumber}, #{avatar}, #{createTime})")
@Options(useGeneratedKeys = true,  keyProperty = "id")
    void insert(User user);
@Select("select * from user where id = #{id}")
    User getById(Long id);
@Select("select count(*) from user where create_time between #{begin} and #{end}")
    Integer getUserByCreateTime(LocalDateTime begin, LocalDateTime end);

    Integer countByMap(Map map);
}
